<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>2_嵌套组件</title>
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
        <h2>{{msg}}</h2><br>
        <!-- 组件标签使用 -->
        <school></school>
    </div>

    <script type="text/javascript">


        // 子组件
        const studentComp = Vue.extend({
            template:`
                <div>
                    <h2>学生姓名；{{stuName}}</h2>
                    <h2>学生年龄；{{stuAge}}</h2>
                    <h2>学生性别；{{stuSex}}</h2>
                </div>
            `,
            data(){
                return {
                    stuName:'詹嫣儿',
                    stuAge:18,
                    stuSex:'女'
                }
            }
        }) 

        // 1.创建组件（简写）
        const schoolComp = {
            template:`
                <div>
                    <h2>学校名称：{{schoolName}}</h2>
                    <h2>学校地址：{{schoolAddr}}</h2>
                    <button @click="showInfo">点我提示学校名</button>
                    <student></student>
                </div>
            `,
            // 组件的data必须是一个函数式：保证组件数据的独立性
            data(){
                return {
                    schoolName:'白兰小学',
                    schoolAddr:'五台县陈家庄乡', 
                }
            },
            methods: {
                showInfo(){
                    alert("学校名：" + this.schoolName)
                }
            },
            components:{
                student:studentComp
            }
        } 
        
        new Vue({
            el:'#root',
            data(){
                return{
                    msg:'欢迎学习Vue'
                }
            },
            // 2.注册组件（局部注册）
            components:{
                school:schoolComp,
            }
        })
    </script>
</body>

</html>